(12) INTERNATIONAL APPLICATION PUBLISHED UNDER THE PATENT COOPERATION TREATY (PCT) 



(19) World Intellectual Property Organization 
International Bureau 

(43) International Publication Date 
12 April 2001 (12.04.2001) 




PCT 



(10) International Publication Number 

WO 01/26032 Al 



(51) International Patent Classification 7 : G06K 1/12, 19/06 

(21) International Application Number: PCT/SEOO/01895 

h 

(22) International Filing Date: 2 October 2000 (02. 10.2000) 

? 

(25) Filing Language: Swedish 



(26") Publication Language: 



English 



(30) Priority Data: 
9903541-2 



I October 1999 (01.10.1999) SE 



(71) Applicant (for all designated States except US): ANOTO 
AB [SE/SE]; c/o C Technologies AB, Scheelevagen 15, 
S-223 70 Lund (SE). 

(72) Inventors; and 

(75) Inventors/Applicants (for US only): PETTERSSON, 
Mats, Petter [SE/SE]; Magjstratsvagen 57E:27, S-226 44 



Lund (SE). EDS6, Torn as [SE/SE]; Renunaregrand 3, 
S-226 51 Lund (SE). 

(74) Agent: AWAPATENT AB; Box 5117, S-200 71 Malmo 
(SE). 

(81) Designated States (national)'. AE, AG, AL, AM, AT, AT 
(utility model), AU, AZ, BA, BB, BG. BR, BY, BZ, CA. 
CH, CN, CR, CU, CZ, CZ (utility model), DE, DE (utility 
model), DK, DK (utility model), DM, DZ, EE, EE (utility 
model), ES, Ft, FT (utility model), GB, GD, GE, GH, GM, 
HR, HU, ID, EL, IN, IS, JP, KE, KG. KP, KR. KR (utility 
model), KZ, LC, LK, LR, LS, LT, LU, LV, MA, MD, MG. 
MK, MN, MW, MX, MZ, NO, NZ, PL, PT, RO, RU, SD. 
SE, SG, SI, SK, SK (utility model), SL, TJ, TM TR, TT, 
TZ, UA, UG, US, UZ, VN, YU, ZA, ZW. 

(84) Designated States (regional): ARIPO patent (GH, GM. 
KE, LS, MW, MZ, SD, SL, SZ, TZ, UG, ZW), Eurasian 
patent (AM, AZ, BY, KG, KZ, MD, RU, TJ, TM), European 
patent (AT, BE, CH, CY, DE, DK, ES, FI, FR, GB, GR, IE, 

(Continued on next page] 



(54) Title: ENCODED PAPER FOR OPTICAL READING 





rn 



f 

.L. 



8 



8 



y 



(57) Abstract: A product provided with a coding pattern which comprises a plurality of marks, each of which represents one of 
at least two different values, and which further comprises a plurality of nominal positions, each of said plurality of marks being 
associated with a nominal position and the value of each mark being determined by its location relative to its nominal position. The 
^* invention also comprises use of the product. 



WO 01/26032 Al WfW^^ 



IT, LU, MC, NL, PT, SE), OAPI patent (BF, BJ, CF, CG, 
O, CM, GA, GN, GW, ML, MR, NE, SN, TD, TG). 

Published: 

— With international search report. 



For two-letter codes and other abbreviations, refer to the "Guid- 
ance Notes on Codes and Abbreviations** appearing at the begin- 
ning of each regular issue of the PCT Gazette. 



WO 01/26032 



PCT/SE00/01895 



ENCODED PAPER FOR OPTICAL READING . 

Field of the Invention 

This invention concerns a product which is provided 
with a coding pattern, which comprises a number of marks, 
each of which represents one of at least two different 
values. The invention also concerns use of such a coding 
5 pattern. 

Background of the Invention 

Storing coded information on a surface by means of 
different types of marks is already known. 

US 5,852,434 describes, for example, a position- 
coding pattern which codes X- Y-cocrdinates for a number 
10 of positions on a writing surface. The position-coding 
pattern makes it possible for a user to record electro- 
nically graphic information which is created on a writ- 
ing surface by continuously reading the position-coding 
pattern . 

15 Three examples of the construction of the position- 

coding pattern are given in US 5,852,434. In the first 
example the pattern consists of symbols, each of which 
■is constructed of three concentric circles. The outer 
circle represents the X-cocrdinate and the middle circle 

20 the Y-ccordinate. Both the outer circles are additionally 
divided into 16 parts which, depending upon whether they 
are filled in or not, indicate different numbers. This 
means that each pair of coordinates X, Y is coded by a 
complex symbol with a particular appearance. 

25 In the second example, the coordinates of each point 

on the writing surface are given by means of bar-codes, 
a bar-code for the X-coordmate being shown above a bar- 
code for the Y-coordinate. 

A chequered pattern which can be used to code the 

30 X- and Y-coordinaces is given as a third example. How- 
ever, there is no explanation as to how the chequered 
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pattern is constructed or how it can be converted into 
coordinates . 

A problem with the known pattern is that it is con- 
structed of complex symbols and the smaller these sym- 
5 bols are made, the more difficult it is to produce the 
patterned writing surface and the greater the risk of 
incorrect position determinat ions , while the larger the 
symbols are made, the poorer the position resolution 
becomes . 

10 A further problem is that the processing of the 

detected position-coding pattern becomes rather compli- 
cated, due to the fact that a processor has to interpret 
complex symbols. 

An additional problem is that the detector or sensor 

15 which is to record the position-coding pattern must be 

constructed in such a way that it can record four symbols 
at the same time so that it is certain to cover at least 
one symbol in its entirety, which is necessary in order 
for the position determination to be able to be carried 

2 0 out. The ratio between the required sensor surface and 

the surface of the position-coding pattern which defines 
a position is thus large. 

In EP 0 578 692 a position-coding pattern is 
described which is constructed of cells in the form of 

25 squares. The value of the cells is determined by their 
appearance, for example their colour. The cells can be 
separated by separation zones so that two adjacent cells 
with the same colour can be distinguished. The position- 
coding pattern differs from that according to US 

30 5,852,434 m that a particular number of cells, that is 

symbols, together code a position. The coding is in addi- 
tion floating, which means that an arbitrary partial sur- 
face of the pattern which contains the above-mentioned 
number of cells codes a position. Each cell thus contri- 

35 butes to the coding of several positions. In this way the 
ratio between the required sensor surface and the part of 
the position-coding pattern which defines a position is 
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less than in the above-mentioned US patent. In addition 
each cell is less complex and therefore the processor 
which is to decode the posit icn-coding pattern needs to 
be able to recognise fewer different elements. However, 
5 the processor needs to be able to locate and distinguish 
at least two different cells. 

EP 0 171 284 Bl shows another floating position- 
coding pattern which is constructed of horizontal and 
vertical lines, the vertical lines coding the position in 

10 the horizontal direction and the horizontal lines coding 
the position in the vertical direction. The lines can be 
found in positions which are a multiple of 1 mm. The pre- 
sence of a line in such a position codes a one (1), the 
absence of a line in such a position codes a zero (0) . 

15 It is, however, difficult to record and decode a 

pattern of lines, as the intersections between the lines 
can be difficult to record. In addition, it is often the 
case that the sensor is not held parallel to the base, 
which results in a perspective where the lines are no 

20 longer parallel. It can then be difficult to determine 
whether a line is actually missing. In addition, there 
must not be too many missing consecutive lines, as dif- 
ficulties can then arise in the decoding. Furthermore, 
the information content is small. 

25 Applicant's Swedish Patent Application SE 9901954-9, 

which was filed on 28 May 1999 and which was not publicly 
available at the time of filing the present application 
and thereby does not constitute prior art, describes an 
additional position-coding pattern of the floating type 

30 in which the position information is coded graphically by 
means of dots of a first and a second size, a dot of the 
first size corresponding to a zero (0) and a dot of the 
second size corresponding to a one (1) . A plurality of 
dots together code the coordinates for a position. 

3 5 It is a general desire that coding patterns which 

are used to store information on a surface must be able 
to code a lot of information per unic area and must be 
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simple to detect and decode even when subjected to inter- 
ference of difference kinds. 
Summary of the Invention 

An object of the present invention is therefore to 
provide a product with a coding pattern which fulfils 
5 this requirement to at least as greac an extent as the 
known coding patterns. 

This object is achieved by means of a product 
according to claim 1. 

The invention concerns more specifically a product 

10 which is provided with a coding pattern, which comprises 
a plurality of marks, each of which represents one of at 
least two different values. The coding pattern comprises 
a plurality of nominal positions, each of said marks 
being associated with one of said plurality c-f nominal 

15 positions and the value of each mark being determined by 
its location relative to its nominal position. 

In prior art the coding is usually carried out by 
means of the appearance of one or more symbols or marks, 
the value of each symbol or mark being determined by its 

20 appearance. The device which decodes the coding pattern 
must consequently be able to recognise different symbols 
or marks, which increases the sensitivity tc interference 
and makes the deccding more difficult. 

According to the present invention, the value of 

2 5 each mark is determined instead by how it is located 

relative to its nominal position. As the value is based 
on the location of the mark, all the marks can have an 
identical appearance. The coding pattern is consequent- 
ly simple to apply on the product. Furthermore, the 

30 detection of the marks is simple to carry out and 

unaffected by the presence of other marks on the product 
which are not part of the coding pattern. In addition, 
the coding pattern can be realised more simply using 
other technology than optical technology, for example as 

35 a chemical, electrical or mechanical pattern. The design 
of the mark also means that a product which is provided 
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with a coding pattern will be more esthetically pleasing 
when the mark is optically readable. Finally, it is pos- 
sible to have a large distance between the marks in rela- 
tion to the density of the information, which means that 
5 the coding pattern. is less sensitive to motion blur which 
can arise during the reading. 

By nominal position is meant in this connection a 
position which is detectable and relative to which the 
mark can be located in different ways. The nominal posi- 

10 tions can be marked on the product, but they can also be 
virtual and detectable indirectly. 

It should also be pointed out that the value which a 
mark represents is preferably a numerical value, but can 
also be a character value, such a letter or some kind of 

15 symbol . 

The Location of the mark can preferably be deter- 
mined by its centre of gravity, which makes possible the 
use of marks of irregular shape and reduces the demands 
when applying the pattern on the product . 

20 In a preferred embodiment , each nominal position is 

allocated a mark. The advantage is hereby obtained that 
all values are coded by a mark. The absence of a mark 
thus always constitutes an error. 

The marks can be placed both in the nominal position 

25 and outside the same. A possible representation of a 

binary pattern could, for example, be that a mark in the 
nominal positxon represents a zero and a mark outside the 
nominal position represents a one, or vice versa. 

In a preferred embodiment, however, essentially all 

3 0 the marks are displaced relative to their nominal posi- 
tion. In this way the pattern is random, while at the 
same time it is so uniform that it appears even to the 
eye . 

A few marks should, however, be able to be in their 
35 nominal position in order to indicate some specific para- 
meters, for example the position of the virtual raster. 
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In addition, in a preferred embodiment, essentially 
all the marks are displaced the same distance relative to 
their nominal position. If it is known where the nominal 
position is located, it is sufficient to look for a mark 
5 at a certain distance from the nominal position, which 
facilitates the locating of the marks and reduces the 
risk of errors. In addition, it is sufficient to detect 
that there is a mark at the relevant distance from the 
nominal position. The appearance of this mark is of sub- 

10 ordinate significance, which reduces the need for preci- 
sion in applying the pattern on the product . 

In a particularly preferred embodiment, each mark is 
displaced in one of four orthogonal directions relative 
to its nominal position. By knowing the nominal position 

15 the mark accordingly only needs to be looked for in four 
different directions. This facilitates and speeds up the 
locating of the marks. In addition, it reduces the risk 
of errors, as marks which are not part of the pattern and 
which are situated in other positions than along the four 

2 0 orthogonal directions are not detected and thereby do not 
run the risk of affecting the decoding of the pattern. 

In order for it to be possible to determine the 
locations of the marks relative to the nominal positions, 
the nominal positions must be known. For this purpose the 

25 coding pattern preferably comprises a raster with raster 
lines, where the intersections of the raster lines define 
the nominal positions of the marks. The nominal positions 
are thus regularly arranged on the product. This facili- 
tates the detection and reduces the risk of error. In 

30 addition, it makes possible the use of a virtual raster. 

In a preferred embodiment, the distance between the 
raster lines is approximately 250 fim to 300 /xm, prefer- 
ably 300 /im. This makes possible a high density of infor- 
mation, but still with reliable detection. 

35 In a preferred embodiment, the raster lines also 

form a rectangular, preferably square, grid. In the 
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latter case, the distance between the raster lines is 
thus the same in both directions. 

In a preferred embodiment, each mark: is additionally 
displaced along one of the raster lines. When the raster 
5 is known, the marks can thus be located in an efficient 
way by searching along the well-defined directions which 
the raster lines represent. 

In a preferred embodiment, each mark is displaced 
from its nominal position by a distance which is 1/4 to 

10 1/8, preferably 1/6, of the distance between the raster 
lines. If the displacement is approximately 1/6 of the 
raster line interval, it is relatively easy to determine 
to which nominal position the mark belongs. If the dis- 
placement is less than approximately 1/8, it can be dif- 

15 ficult to detect, that is the resolution requirement is 

too great. If the displacement is more than approximately 
1/4, it can be difficult to determine to which nominal 
position the mark belongs. This applies in particular if 
the representation of the coding pattern recorded by the 

20 sensor or detector is distorted, which for example can 
occur if an optical sensor is held at an angle relative 
to the surface on which the coding pattern is arranged. 
With the above-mentioned preferred raster line interval 
of 300 fixn, the preferred displacement is thus 50 M m - 

25 The raster with the raster lines can be indicated 

on the surface in such a way that it can be read directly 
by the device which detects the marks. In this case, 
however, the raster must also be able to be detected by 
the device and distinguished from the marks. In a prefer- 

30 red embodiment, the raster is instead virtual, which 

means that it is not marked on the product in any way, 
but can be located from the locations of the marks. 
Instead of being read from the product, it is thus deter- 
mined indirectly by means of the marks . 

35 As already mentioned, essentially all the marks 

in a preferred embodiment have an essentially identical 
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appearance. This makes it simpler to arrange them on the 
product . 

The marks have preferably some simple geometric 
shape. They are thus advantageously approximately cir- 
5 cular, triangular or rectangular. They can be filled- in 
or not, but the former is preferable as detection is then 
simpler . 

The mark should not cover its nominal position and 
should therefore not have a larger diameter than twice 

10 the displacement, that is 200%. This is, however, not 

critical, as a certain amount of overlapping is permis- 
sible, for example 240%. The smallest size is determin- 
ed in the first place by the resolution of the sensor and 
the requirements of the printing process used to produce 

15 the pattern. However, in practice the marks should not 
have a smaller diameter than approximately 50% of the 
displacement, in order to avoid problems with particles 
and noise in the sensor. 

The coding pattern can be realised with any para- 

2 0 meters which can be used to produce marks of the above- 
mentioned type which can be detected by a detector. The 
parameters can be electrical or chemical or of some other 
.type. The coding pattern is, however, preferably optical- 
ly readable in order for it to be simpler to arrange on 

25 the product. It can, for example, be printed on the pro- 
duct . 

In a preferred embodiment, the coding pattern is 
readable by infrared light. In this way information which 
is not readable by infrared light can be overlaid on the 
30 coding pattern without interfering with the reading of 
this . 

In a preferred embodiment, the marks constitute 
0.25% to 20%, preferably approximately 9%, of the surface 
which is taken up by the coding pattern. If the pattern 
35 is printed, for example, on a sheet of white paper, it 
will in this case only result in a pale grey shading of 
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the paper, which means than it will appear as essentially 
normal paper. 

The coding pattern is preferably a position-coding 
pattern which codes a plurality of positions on the pro- 
5 duct, each position being coded by means of a plurality 
of marks. The coding pattern can, however, also be used 
to code other information. 

The product can be any product which can be provided 
with a coding pattern. It does not need to be a physical 

10 product, but can also be electronic, for example an image 
or a surface on a computer screen on which the coding 
pattern is overlaid in electronic form. 

According to another aspect of the invention, this 
concerns use of a coding pattern which comprises a plu- 

15 raiity of marks, each of which represents one of at least 
two different values, and a plurality of nominal posi- 
tions, each of said plurality of marks being associated 
with one of said plurality of nominal positions and the 
value of each mark being determined by its location rela- 

20 tive to its nominal position. 

The advantages of the use of such a pattern are 
apparent from the discussion of the coding pattern on the 
product. The features which are mentioned for the coding 
pattern on the product also apply, of course, :o the use 

25 of the coding pattern. The use can, for example, consist 
of printing out the coding pattern on a product, storing 
the coding pattern in electronic form or decoding the 
coding pattern. 

Brief Description of the Drawings 

In the following the invention will be described in 
3 0 greater detail by way of an embodiment and with reference 
to the accompanying drawings, in which 

Fig. 1 shows schematically an embodiment of a pro- 
duct which is provided with a posit ion- coding pattern; 
Fig. 2 shows schematically how the marks can be 
35 designed and positioned in an embodiment of the inven- 
tion ; 
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Fig. 3 shows schematically an example of 4*4 symbols 
which are used to code a position; 

Fig. 4 shows schematically a device which can be 
used for position determination; 
5 Fig. 5 shows schematically a position-coding pattern 

with triangular raster; and 

Fig. 6 shows schematically a position-coding pattern 
with hexagonal raster. 

Description of a Preferred Embodiment 

Fig. 1 shows a part of a product in the form of a 

10 sheet of paper 1, which on at least part of its surface 2 
is provided with an optically readable position-coding 
pattern 3 which makes possible position determination. 

The position-coding pattern comprises marks 4, which 
are systematically arranged across the surface 2, so that 

15 it .has a "patterned" appearance. The sheet of paper has 
an X-coordinate axis and a Y-coordinate axis. The posi- 
tion determination can be carried out on the whole sur- 
face of the product. In other cases the surface which 
enables position determination can constitute a small 

2 0 part of the product. 

The pattern can, for example, be used to provide an 
.electronic representation of information which is written 
or drawn on the surface. The electronic representation 
can be provided, while writing on the surface with a pen, 

25 by continuously determining the position of the pen on 
the sheet of paper by reading the position-ceding pat- 
tern. 

The position-coding pattern comprises a virtual 
raster, which is thus neither visible to the eye nor can 

30 be detected directly by a device which is to determine 
positions on the surface, and a plurality of marks 4, 
each of which, depending upon its location, represents 
one of four values " 1 " to "4 M as described below. In this 
connection it should be pointed out that for the sake of 

35 clarity the position-coding pattern in Fig. 1 is greatly 
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enlarged. In addition, it is shown arranged only on part 
of the sheet cf paper. 

The position-coding pattern is so arranged that the 
position of a partial surface on the total writing sur- 
5 face is determined . unambiguously by the marks on this 

partial surface. A first and a second partial surface 5a, 
5b are shown by broken lines in Fig. 1. The second par- 
tial surface partly overlaps the first partial surface. 
The part of the position-coding pattern (here 4*4 marks) 

,10 on the first partial surface 5a codes a first position 

and the part of the position-coding pattern on the second 
partial surface 5b codes a second position. The position- 
coding pattern is thus partly the same for the adjoining 
first and second positions. Such a position-coding pat- 

15 tern is called "floating" in this application. Each par- 
tial surface codes a specific position. 

Figs 2a-d show how a mark can be designed and how 
it can be located relative to its nominal position 6. The 
nominal position 6, which also can be called a raster 

20 point, is represented by the intersection of the raster 
lines 8. The mark 7 has the shape of a circular dot. A 
mark 7 and a raster point 6 can together be said to con- 
stitute a symbol . 

In one embodiment, the distance between the raster 

25 lines is 300 fim and the angle between the raster lines 
is 90 degrees. Other raster intervals are possible, for 
example 254 am to suit printers and scanners which often 
have a resolution which is a multiple of 100 dpi, which 
corresponds to a distance between points of 25.4 mm/100, 

30 that is 254 /im. 

The value of the mark thus depends upon where the 
mark is located relative to the nominal position. In the 
example in Fig. 2 there are four possible locations, one 
on each of che raster lines extending from the nominal 

35 position. The displacement from the nominal position is 
the same size for all values. 
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Each mark 7 is displaced relative to its nominal 
position 6, that is no mark is located at the nominal 
position. In addition, there is only one mark per nominal 
position and -his mark is displaced relative to its nomi - 
5 nal position. This applies to the marks which make up the 
pattern. There can be other marks on the surface which 
are not part of the pattern and thus do not contribute 
to the coding. Such marks can be specks of dust, uninten- 
tional points or marks and intentional marks, from for 

10 example a picture or figure on the surface. Because the 
position of the pattern marks on the surface is so well- 
defined, the pattern is unaffected by such interference. 

In one embodiment, the marks are displaced by 50 ptm 
relative to the nominal positions 6 along the raster 

15 lines 8. The displacement is preferably 1/6 of the raster 
interval, as it is then relatively easy to determine to 
which nominal position a particular mark belongs. The 
displacement should be at least approximately 1/8 of the 
raster interval, otherwise it becomes difficult to deter- 

20 mine a displacement, that is the requirement for resolu- 
tion becomes great. On the other hand, the displacement 
should be less than approximately 1/4 of the raster 
interval in order for it to be possible to determine to 
which nominal position a mark belongs. 

25 The displacement does not need to be along the 

raster line, but the marks can be positioned in separate 
quadrants. However, if the marks are displaced along the 
raster lines, the advantage is obtained that the distance 
between the marks has a minimum which can be used to 

30 recreate the raster lines, as described in greater detail 
below . 

Each mark consists of a more or less circular dot 
with a radius which is approximately the same size as the 
displacement or somewhat less. The radius can be 25% to 
35 120% of the displacement. If the radius is much larger 
than the displacement, it can be difficult to determine 
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the raster lines. If the radius is too small, a greater 
resolution is required to record the marks. 

The marks do not need to be circular or round, buz 
any suitable shape can be used, such as square or trian- 
5 gular, etc. 

Normally, each mark covers a plurality of pixels on 
a sensor chip and, in one embodiment, the centre of gra- 
vity of these pixels is recorded or calculated and used 
in the subsequent processing. Therefore the precise shape 
10 of the mark is of minor significance. Thus relatively 

simple printing processes can be used, provided it can be 
ensured that the centre of gravity of the mark has the 
required displacement . 

In the following, the mark m Fig. 2a represents the 
15 value 1, in Fig. 2b the value 2, in Fig. 2c the value 3 
and in Fig. 2d the value 4. 

Each mark can thus represent one of four values "1 
to 4". This means that the position-coding pattern can be 
divided into a first position code for the x-cocrdinate 
20 and a second position code for the y- coordinate . The 
division is carried out as fellows: 



Mark value 


code 


v-code 




i 


i 


—i 
& 


0 


1 




1 


0 


4 


0 


0 



The value of each mark is thus converted into a 
25 first value, here bit, for the x-code and a second 

value, here bit, for the y-code. In this way two com- 
pletely independent bit patterns are obtained by means 
of the pattern. Conversely, two or more bit patterns can 
be combined into a common pattern which is coded graphi- 
30 cally by means of a plurality of marks in accordance with 
Fig. 2. 
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Each position is ceded by means of a plurality of 
marks. In this example, 4*4 marks are used to code a 
position in two dimensions, that is an x-coordinate and 
a y-coordinate . 

5 The position cede is constructed by means of a num- 

ber series of ones and zeros, a bit series, which has the 
characteristic that no four bit long bit sequence occurs 
more than once in the bit series. The bit series is 
cyclic, which means that "he characteristic also applies 
10 when the end of the series is connected to its beginning. 
A four-bit sequence has thus always an unambiguously 
determined position number in the bit series. 

The bit series can be a maximum of 15 bits long if 
it is to have -he characteristic described above for bit 
15 sequences of four bits. In this example, however, only a 
seven bit long bit series is used, as follows: 
"0001010". 

This bit series contains seven unique bit sequences 
of four bits which code a position number in the series 
20 as follows : 



Position number in the series 


Sequence 


0 


0001 




0010 


2 


0101 


3 


1010 


4 


0100 


5 


1000 


6 


0000 



To code the x-coordinate, the bit series is written 
sequentially in columns ever all the surface which is to 
25 be coded, where the left column K 0 corresponds to the 

x-coordinate zero (0) . In one column the bit series can 
thus be repeated several times in succession. 

The coding is based on differences or position 
displacements between adjacent bit series in adjacent 
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columns. The size of the difference is determined by 
the position number (that is the bit sequence) in the 
bit series with which the adjacent columns commence. 
More precisely, if one takes the difference A n 
5 modulo seven between, on the one hand, a position number 
which is coded by a four-bit sequence in a first column 
K n and which can thus have the value 0 to 6, and, on the 
other hand, a position number which is coded by an adja- 
cent four-bit sequence at a corresponding "height" in an 

10 adjacent column K n+i , the difference will be the same 

regardless of where, that is at what "height", along the 
two columns the difference is created. Using the diffe- 
rence between the position numbers for two bit sequences 
in two adjacent columns, it is thus possible to code an 

15 x-coordinate which is independent of and constant for all 
y-coordinates . 

As each position on the surface is coded by a par- 
tial surface consisting of 4*4 marks in this example, 
there are four vertical bit sequences available and thus 

20 three differences, each with the value 0 to 6, for coding 
the x-coordinate. 

The pattern is divided into code windows F with 
the characteristic that each code window consists of 
4*4 marks. There are thus four horizontal bit sequences 

25 and four vertical bit sequences available, so that three 
differences can be created in the x-direction and four 
positions can be obtained in the y-direction. These 
three differences and four positions code the position of 
the partial surface in the x-direction and the y-direc- 

3 0 tion. Adjacent windows in the x-direction have a common 
column, see Fig. 1. Thus the first code window F 0(0 con- 
tains bit sequences from the columns K 0/ Ki , K 2 / K 3 , and 
bit sequences from the rows R 0/ R L , R 2 # R3 - As differences 
are used in the x-direction, the next window diagonally 

35 in the x-direction and y-direction, the window F 1#1 , con- 
tains bit sequences from the columns K 3 , K 4 , K 5 , K 6 , and 
the rows R 4 , R 5/ R 6 , R 7 . Considering the coding in just 
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the x-direction, the code window can be considered to 
have an unlimited extent in the y-direction. 
Correspondingly, considering the coding in just the y- 
direction, the code window can be considered to have an 
5 unlimited extent in the x-direction. Such a first and 
second code window with unlimited extent in the y- 
direction and x-direction respectively together form a 
code window of the type shown in Fig. 1, for example F 0 ,o- 
Each window has window coordinates F x , which give 

10 che position of the window in the x-direction, and F y , 

which give the position of the window in the y-direction. 
Thus the correspondence between the windows and columns 
is as follows. 
Ki = 3 F x 

15 Rj = 4 F y 

The coding is carried out in such a way that for the 
three differences, one of the differences A 0 always has 
the value 1 or 2 , which indicates the least significant 
digit S 0 for the number which represents the position of 

20 the code window in the x-direction, and both the other 

differences Ai, A 2 , have values in the range 3 to 6, which 
indicates the two most significant digits S x , S 2 , for zhe 
coordinate of the code window. Thus no difference can be 
zero for the x- coordinates , as that would result in too 

25 symmetrical a code pattern. In other words, zhe columns 
are coded so that the differences are as follows: 
(3 to 6); (3 to 6); (1 to 2); (3 to 6); (3 to 6); (1 to 
2); (3 to 6); (3 to 6); (1 to 2); (3 to 6); (3 to 6); ... 
Each x-coordinate is thus coded by two differences 

3 0 Ai, A 2 of between 3 and 6 and a subsequent difference A 0 
which is 1 or 2. By subtracting one (1) from the least 
difference A 0 and three (3) from the other differences, 
three digits are obtained, S 2 , Si, So," which in a mixed 
base directly give the position number of the code window 

35 in the x-direction, from which the x-coordinate can then 
be determined directly, as shown in the example below. 
The position number of the code window is: 
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£ 2 * (4*2) + Si * 2 - S 0 * 1 

Using the principle described above, it is thus pos- 
sible to code code windows 0, 1, 2, 31, using a 
position number for the code window consisting of three 
5 digits which are represented by three differences. These 
differences are coded by a bit pattern which is based on 
the number series above. The bit pattern can finally be 
coded graphically by means of the marks in Fig. 2. 

In many cases, when a partial surface is recorded 

10 consisting of 4*4 marks, a complete position number which 
codes the x-coordinate will not be obtained, but parts of 
two position numbers will, as the partial surface in many 
cases does no* coincide wizh one cede window but covers 
parrs of two adjacent code windows in the x-direction. 

15 However, as the difference for the least significant 
digit S 0 of each number is always 1 or 2 , a complete 
position number can easily be reconstructed, as it is 
known what digit is the least significant. 

The y- coordinates are coded in accordance with 

20 approximately the same principle as that used for the 

x-coordinates by means of code windows. The cyclic num- 
ber series, that is the same number series as is used for 
the x-coding, is written repeatedly in horizontal rows 
across the surface which is to be position coded. Pre- 

25 cisely as for the x-coordinates, the rows are made to 

start in different positions, that is with different bit 
sequences, in the number series. For the y-coordinates , 
however, differences are not used, but the coordinates 
are coded by values which are based on the start position 

3 0 of the number series in each row. When the x-coordinate 

has been determined for a partial surface with 4*4 marks, 
the start positions in the number series can in fact be 
determined for the rows which are included in the y-code 
for the 4*4 marks. 

35 In the y-code, the least significant digit S 0 is 

determined by letting this be the only digit which has 
a value in a particular range. In this example, a row of 



WO 01/26032 



PCT/SEOO/01895 



13 

four starts in position 0 to 1 in the number series, in 
order to indicate that this row concerns the least sig- 
nificant digit S 0 in a code window, and the three other 
rows start in any of the positions 2 to 6 in order to 
5 indicate the other digits Si S 2 S 3 in the code . window. 
In the y-direction there is thus a series of values as 
follows : 

(2 to 6) ; (2 to 6) ; (2 to 6) ; (0 to 1) ; (2 to 6) ; (2 to 
6); (2 to 6); (0 to 1); (2 to 6); ... 

10 Each code window is thus coded by three values 

between 2 and 6 and a subsequent value between 0 and 1 . 

If zero (0) is subtracted from the low value and two 
(2) from the other values, a position in the y-direction 
S 3 S 2 Si S 0 in mixed base is obtained, in a way similarly 

15 to the x-direction, from which the position number of the 
code window can be determined directly, which is: 
S 3 * (5*5*2) + S 2 * (5*2) + Si * 2 + So * 1 
Using the method above, it is possible to code 
4 * 4 * 2 = 32 position numbers in the x-direction 

20 for the code windows. Each code window comprises bit 
sequences from three columns, which gives 3 * 32 = 96 
columns or x-coordinates . In addition, it is possible 
to code 5*5*5*2= 250 position numbers in the 
y-direction for the code windows. Each such position 

25 number comprises horizontal bit sequences from 4 rows, 
which gives 4 * 250 = 1000 rows or y-coordinates . In 
total it is thus possible to code 96000 coordinate posi- 
tions . 

As the x-coding is based on differences, it is, 
30 however, possible to select the position in which the 

first number series in the first code window starts. If 
it is taken into account that this first number series 
can start in seven different positions, it is possible to 
code 7 * 96000 = 672000 positions. The start position of 
35 the first number series in the first column K 0 can be 

calculated when the x- and y-coordinates have been deter- 
mined. The above-mentioned seven different snart posi- 
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tions for the first series can code different pages or 
writing surfaces of a product. 

Theoretically, a partial surface with 4*4 symbols, 
which each have four values, can code 4 4 * 4 positions, 
5 that is 4,294,967,296 positions. In order :o make pos- 
sible floating determination of the position of a partial 
surface, there is thus a redundancy factor in excess of 
6000 (4294967296/672000) . 

The redundancy consists partly in the restrictions' 

10 on the size of the differences, and partly in only 7 bits 
out of 16 being used in the position code. This latter 
fact can, however, be used to determine the rotational 
position of the partial surface. If the next bit in the 
bit series is added to the four-bit sequence, a five-bit 

15 sequence is obtained. The fifth bit is obtained by read- 
ing the adjacent bit immediately outside the partial sur- 
face which is being used. Such an additional bit is often 
easily available. 

The partial surface which is read by the sensor can 

20 have four different rotational positions, rotated through 
0, 90, 180 or 270 degrees relative to the code window. In 
those cases where the partial surface is rotated, the 
.reading of the code will, however, be such that the code 
read will be inverted and reversed in either the x-direc- 

25 tion or the y-direction or both, in comparison to the 
case where if it had been read at 0 degrees. This 
assumes, however, that a slightly different decoding of 
the value of the marks is used according to the table 
below. 

30 



Mark value 


x-code 


y-code 


1 


0 


0 


2 


1 


0 


3 


1 


1 


4 


0 


1 
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The above-mentioned five-bit sequence has the char- 
acteristic that it only occurs the right way round and 
not in inverted and reversed form in the seven-bit 
series. This is apparent from the fact that the bit 
5 series (0001010) contains only two "ones". There- 
fore all five-bit sequences must contain at least three 
zeros, which after inversion (and reversing, if any) 
results in three ones, which cannot occur. Thus if a 
five-bit sequence is found which does not have a position 
10 number in the bit series, it can be concluded that the 
partial surface should probably be rotated and the new 
position tested. 

In order to provide further illustrations of the 
invention according to this embodiment, here follows 
15 a specific example which is based on the described embo- 
diment cf the position code. , 

Fig. 3 shows an example of an image with 4*4 marks 
which are read by a device for position determination. 
These 4*4 marks have the following values: 
20 4 4 4 2 

3 2 3 4 

4 4 2 4 
13 2 4 

These values represent the following binary x- and 
25 y-codes: 

x-code : y-code : 

0000 0001 
1010 0100 
0000 0010 
30 1100 1010 

The vertical bit sequences in the x-code code the 
following positions in the bit series: 2 0 4 6. The dif- 
ferences between the columns are -2 4 2, which modulo 7 
gives: 5 4 2, which in mixed base codes the position num- 
3 5 ber of the code window: (5-3) * 8 + (4-3) * 2 + (2-1) - 
16 + 2 r 1 = 19. The first coded code window has the 
posicion number 0. Thus che difference which lies in 
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the range 1 to 2 and which appears in the 4*4 marks 
of the partial surface is the twentieth such diffe- 
rence. As additionally there are in total three columns 
for each such difference and there is a starting column, 
5 the vertical sequence furthest to the right in the 4*4 
x-code belongs to the 61st column (column 60) in the 
x-code (3 * 20 + 1 = 61) and the vertical sequence fur- 
thest to the left belongs to the 58th column (column 57) . 
The horizontal bit sequences in the y-code code the 

10 positions 0 4 1 3 in the number series. As these hori- 
zontal bit sequences start in the 58th column, the start 
position of the rows is the value of these minus 57 
modulo 7, which gives the start positions 6 3 0 2. Con- 
verted to digits in the mixed base, this becomes 6-2, 

15 3-2, 0-0, 2-2 =4100, where the third digit is the 
, least significant digit in the number concerned. The 
fourth digit is then the most significant digit in the 
next number. It must in this case be the same as in the 
number concerned. (The exception is when the number con- 

20 cerned consists of highest possible digits in all posi- 
tions. Then it is known that the beginning of the next 
number is one greater than the beginning of the number 
concerned. ) 

The position number is in mixed base 0*50 + 4*10 
25 + 1*2 +0*1 = 42. 

The third horizontal bit sequence in the y-code thus 
belongs to the 43rd code window which has a start posi- 
tion 0 or 1, and as there are four rows in total for each 
such code window, the third row is number 43*4=172. 
3 0 In this example, the position of the top left corner 

of the partial surface with 4*4 marks is (58,170). 

As the vertical bit sequences in the x-code in 
the 4*4 group start at row 170, the whole pattern's 
x-columns start in the positions of the number series 
35 ((2046) -169) modulo 7=1635. Between the last 

start position (5) and the first start position the num- 
bers 0-19 are coded in the mixed base, and by adding the 
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representations of the numbers 0-19 in the mixed base the 
total difference between these columns is obtained. A 
naive algorithm for doing this is to generate these 
twenty numbers and directly add their digits. Call the 
5 sum obtained s. The page or writing surface is then given 
by ( 5 -s) modulo? . 

An alternative method for determining which bit is 
the least significant in a partial surface in order to be 
able to identify a code window in this way is as follows. 

10 The least significant bit (LSB) is defined as the digit 
which is the lowest in a partial surface's differences 
or row position number. In this way the reduction (redun- 
dancy) of the maximum useable number of coordinates is 
relatively small. For example, the first code windows in 

15 the x-direction in the example above can all have LSB=1 
and other digits, between 2 and 6, which gives 25 code 
windows, the next can have LSB=2 and other digits between 
3 and 6, which gives 16 code windows, the next can have 
LSB=3 and other digits between 4 and 6, which gives 9 

20 code windows, the next can have LSB=4 and other digits 

between 5 and 6, which gives 4 code windows, the next can 
have LSB=5 and other digits 6, which gives 1 code window, 
.that is a total of 55 code windows, compared to 32 in the 
example above. 

2 5 In the example above, an embodiment has been 

described where each code window is coded by 4*4 marks 
and a number series with 7 bits is used. This is of 
course only one example. Positions can be coded by more 
or fewer marks. There does not need to be the same number 

30 in both directions. The number series can be of different 
length and does ' not need to be binary, but can be based 
on a different base, for example hex code. Different 
number series can be used for coding in the x-direction 
and coding in the y-direction. The marks can represent 

35 different numbers of values. 

In a practical example, a partial surface is used 
consisting of 5*6 marks and where the bit series as a 
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maximum can consist of 2 6 bits, that is 64 bits. However, 
a bit series consisting of 51 bits is used, and conse- 
quently 51 positions, in order co have the ability to 
determine the rotational position of the partial surface. 
5 An example of such. a bit series is: 

000001100011111 0 1010110110011 
0100010100111011110010 

Such a partial surface consisting of six by six 
marks can theoretically code 4 6 * 6 positions, which with 

10 the above-mentioned raster dimensions of 0.3 mm is an 
extremely large surface. 

In a similar way as described above for the seven- 
bit series, according to the present: invention the 
characteristic is utilised that the partial surface is 

15 enlarged to include one bit on each side of the partial 
surface, at least at its centre, so chat for the third 
and fourth rows in the partial surface of 6*6 symbols, 
8 symbols are read, one on each side of the partial sur- 
face, and similarly in the y-direction. The above-men- 

20 tioned bit series which contains 51 bits has the charac- 
teristic that a bit sequence of 6 bits occurs only once 
and that a bit sequence of 8 bits which contains the 
.above-mentioned bit sequence of 6 bits occurs only once 
and never in an inverted position or reversed and 

25 inverted. In this way, the rotational position of the 
partial surface can be determined by reading 8 bits in 
row 3, row 4, column 3 and/or column 4. When the rota- 
tional position is known, the partial surface can be 
rotated to the correct position before the processing 

3 0 is continued. 

It is desirable to obtain a pattern which is as 
random as possible, that is where areas with excessive 
symmetry do not occur. It is desirable to obtain a pat- 
tern where a partial surface with 6*6 marks contains 

35 marks with all the different positions in accordance 

with Figs 2a to 2d. In order to increase the randomness 
further or avoid repetitive characteristics, a method can 
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be used which is called "shuffle". Each horizontal bit 
sequence starts in a predetermined start position. How- 
ever, it is possible to displace the start position in 
the horizontal direction for each row, if the displace- 
5 ment is known. This can be carried out by each least sig- 
nificant bit (LSB) being allocated a separate displace- 
ment vector for the adjacent rows. The displacement vec- 
tor states by how much each row is displaced in the hori- 
zontal direction. Visually it can be regarded as if the 

10 y-axis in Fig. 1 is "spiky". 

In the example above, with a 4*4 code window, the 
displacement vector can be 1 , 2, 4, 0 for LSB = 0 and 
2, 2, 3, 0 for LS3=1. This means that after subtracting 
the number 2 and 0 respectively, the above displacement 

15 is :o be subtracted (modulo five) from the bit sequence's 
position number, before the processing continues. In the 
example above, for the y-coordinate the digits 4 10 0 
(S 2 , Si, S 0 , S 4 ) are obtained in the mixed base, where the 
second digit from the right is the least significant 

20 digit, LSB. As the displacement vector 1, 2, 4, 0 is to 
be used (LSB=0) for the digits 4 and 1, 2 is subtracted 
from 4 to give S 2 = 2 and 4 is subtracted from 1 (modulo 
.five) to give Si = 2 . The digit S o = 0 remains unchanged (the 
displacement vector's component for the least significant 

25 digit is always zero) . Finally, the digit S 4 belongs to 
the next code window, which must have LSB=1, that is the 
second displacement vector is to be used. Thus 2 is sub- 
tracted from 0 (modulo five) which gives S 4 = 3 . 

A similar method can be used to change the codes for 

30 the x-coordinates . However, there is less need to change 
the x-coordinates, as they are already relatively random- 
ly distributed, as the difference zero is not used, in 
the example above . 

In the example above, the mark is a dot. Naturally 

35 it can have a different appearance. It can, for example, 
consist of a line or an ellipse, which starts at the vir- 
tual raster point and extends from this to a particular 
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position. Other symbols than a dot can be used, such as a 
square, rectangle, triangle, circle or ellipse, filled-in 
or not . 

In the example above, the marks are used within a 
5 square partial surface for coding a position. The partial 
surface can be another shape, for example hexagonal. The 
marks do not need to be arranged along the raster lines 
in an orthogonal raster but can also be arranged in other 
manners, such as along the raster lines in a raster with 
10 60 degree angles, etc. A polar coordinate system can also 
be used. 

Rasters in the form of triangles or hexagons can 
also be used, as shown in Figs 5 and 6. For example, a 
raster with triangles, see Fig. E, enables each mark to 

15 be displaced in six different directions, which provides 
even greater possibilities, corresponding to 6 6 " 6 partial 
surface positions. For a hexagonal raster, Fig. 6, a 
honeycomb pattern, each mark can be displaced in three 
different directions along the raster lines. 

2 0 As mentioned above, the marks do not need to be dis- 

placed along the raster lines but can be displaced in 
other directions, for example in order to be located each 
in a separate quadrant when using a square raster pat- 
tern. In che hexagonal raster pattern the marks can be 

25 displaced in four or more different directions, for exam- 
ple in six different directions along the raster lines 
and along lines which are at 60 degrees to the raster 
lines . 

In order for the position code to be able to be 
30 detected, it is necessary for the virtual raster to be 
determined. This can be carried out, in a square raster 
pattern, by examining the distance between different 
marks. The shortest distance between two marks must 
originate from two adjacent marks with the values 1 and 3 
35 in the horizontal direction or 2 and 4 in the vertical 

direction, so that the marks lie on the same raster line 
between two raster points. When such a pair of marks has 
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been detected, the associated raster points (the nominal 
positions) can be determined using knowledge of the dis- 
tance between the raster points and the displacement of 
the marks from the raster points. Once two raster points 
5 have been located, . additional raster points can be deter- 
mined using the measured distance to other marks and from 
knowledge of the distance between the raster points. 

If the marks are displaced 50 /im along the raster 
lines, which are a distance of 300 /im apart, the least 

10 distance between two marks will be 200 /im, for example 

between marks with the values 1 and 3 . The next smallest 
distance arises between, for example, marks with the 
values 1 and 2, and is 255 pirn. There is therefore a rela- 
tively distinct difference between the least and the next 

15 smallest distance. The difference to any diagonals is 

also great. However, if the displacement is larger than 
50 /im, for example more than 75 /im (1/4) , diagonals can 
cause problems and it can be difficult to determine to 
which nominal position a mark belongs. If the displace- 

20 ment is less than 5 0 /im, for example less than approxi- 
mately 35 jum (1/8) , the least distance will be 230 /im, 
which does not give a very large difference to the next 
distance, which is then 26 7 /im. In addition, the demands 
on the optical reading increase. 

25 The marks should not cover their own raster point 

and should therefore not have a larger diameter than 
twice the displacement, that is 200%. This is, however, 
not critical, and a certain overlapping can be permitted, 
for example 240%. The least size is determined in the 

30 first place by the resolution of the sensor and the 

demands of the printing process used to produce the pat- 
tern. However, the marks should not have a smaller dia- 
meter than approximately 50% of the displacement in prac- 
tice, in order to avoid problems with particles and noise 

3 5 in the sensor. 

An embodiment of a device for position determination 
is shown schematically in Fig. 4. It comprises a casing 
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11 which has approximately the same shape as a pen. In 
the short side of the casing there is an opening 12 . The 
short side is intended to abut against or to be held a 
short distance from the surface on which the position 
5 determination is to be carried out. 

The casing contains essentially an optics part, an 
electronic circuitry part and a power supply. 

The optics part comprises at least one light-emit- 
ting diode 13 for illuminating the surface which is to be 
10 imaged and a light-sensitive area sensor 14, for example 
a CCD or CMOS sensor, for recording a two-dimensional 
image. If required, the device can also contain an opti- 
cal system, such as a mirror and/or lens system. The 
light -emit ting diode can be an infrared light-emitting 
15 diode and the sensor can be sensitive to infrared light. 

The power supply for the device is obtained from a 
battery 15, which is mounted in a separate compartment in 
the casing. 

The electronic circuitry part contains image- 

2 0 processing means 16 for determining a position on the 

basis of the image recorded by the sensor 14 and in 
particular a processor unit with a processor which is 
. programmed to read images from the sensor and carry out 
position determination on the basis of these images. 
25 In this embodiment, the device also comprises a pen 

point 17, with the aid of which ordinary pigment -based 
writing can be written on the surface on which the posi- 
tion determination is to be carried out. The pen point 17 
is extendable and retractable so that the user can con- 

3 0 trol whether or not it is to be used. In certain applica- 

tions the device does not need to have a pen point at 
all. 

The pigment -based writing is suitably of a type that 
is transparent to infrared light and the marks suitably 
35 absorb infrared light. By using a light-emitting diode 
which emits infrared light and a sensor which is sensi- 
tive to infrared light, the detection of the pattern can 
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be carried out without the above-mentioned writing inter- 
fering with the pattern. 

The device also comprises buttons 18, by means of 
which the device can be activated and controlled. It has 
5 also a transceiver- 19 for wireless cransmission, for 

example using infrared light, radio waves or ultrasound, 
of information to and from the device. The device can 
also comprise a display 20 for displaying positions or 
recorded information . 

10 A device for recording text is described in Appli- 

cant's Swedish Patent No. 9604008-4. This device can be 
used for position determination if it is programmed in a 
suitable way. If it is to be used for pigment -based writ- 
ing, then it must also be given a pen point. 

15 The device can be divided between different physical 

casings, a first casing containing components which are 
required for recording images of the position-coding pat- 
tern and for transmitting these to components which are 
contained in a second casing and which carry out the 

20 position determination on the basis of the recorded 
image ( s ) . 

As mentioned, the position determination is carried 
out by a processor which thus must have software for 
locating marks in an image and decoding them and for 

25 determining positions from the codes thus obtained. A 
person skilled in the art will be able, based on the 
example above, to design software which carries out 
position determination on the basis of an image of a part 
of a position-coding pattern. 

30 In addition, on the basis of the description above, 

a person skilled in the art will be able to design soft- 
ware for printing out the posit ion- coding pattern. 

In the embodiment above, the pattern is optically 
readable and the sensor is therefore optical . As mention- 

35 ed, the pattern can be based on a parameter other than 
an optical parameter. In such a case the sensor must of 
course be of a type which car. read the parameter con- 
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cerned. Examples of such parameters are chemical, acous- 
tic or electromagnetic marks. Capacitive or inductive 
marks can also be used. 

In the embodiment above, the raster is an orthogonal 
5 grid. It can also have other forms, such as a rhombic 

grid, for example with 60 degree angles, a triangular or 
hexagonal grid, etc. 

Displacement in more or less than four directions 
can be used, for example displacement in three directions 

10 along a hexagonal virtual raster. In an orthogonal raster 
only two displacements can be used, in order to facili- 
tate the recreation of the raster. However, a displace- 
ment in four directions is preferred, but six or eight 
directions are also possible within the scope of the 

15 invention. 

In the embodiment above, che longest possible cyclic 
number series is not used. As a result, a degree of 
redundancy is obtained which can be used in various ways, 
for example to carry out error correcting, replace miss- 

20 ing or hidden marks, etc. 
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1. A product which is provided with a coding pat- 

5 tern, which comprises a plurality of marks, each of which 
represents one of at least two different values, 
characterised in that the coding pattern also 
comprises a plurality of nominal positions, each of "said 
plurality of marks being associated with one of said 
10 plurality of nominal positions and the value of each mark 
being indicated by its location relative to its nominal 
position . 

2. A product according to claim 1, in which each 
nominal position is allocated a mark. 

15 3. A product according to claim 1 or 2, in which 

essentially all the marks are displaced relative, to their 
nominal positions . 

4. A product according to claim 3, in which essen- 
tially all the marks are displaced the same distance 

20 relative to their nominal positions. 

5. A product according to any one of the preceding 
claims, in which each mark is displaced in one of four 
orthogonal directions relative to its nominal position. 

6 . A product according to any one of the preceding 
25 claims, in which the coding pattern comprises a raster 

with raster lines, where the intersections of the raster 
lines define the nominal positions of the marks. 

7. A product according to claim 6, in which the dis- 
tance between the raster lines is approximately 250 ^m to 

3 0 3 00 /zm. 

8. A product according to claim 6 or 7, in which the 
raster lines form a rectangular, preferably square, grid. 

9. A product according to claim 6, 7 or 8, in which 
each mark is displaced along one of the raster lines. 

3 5 10. A product according to any one of claims 6-9, in 

which each mark is displaced from its nominal position by 
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a distance which is 1/4 to 1/8, preferably 1/6, of the 
distance between the raster lines. 

11. A product according to any one of claims 6-10, 
in which the rascer is virtual. 
5 12 . A product .according to any one of the preceding 

claims, in which all the marks have an essentially iden- 
tical appearance. 

13 . A product according to any one of the preceding 
claims, in which the marks are approximately circular, 

10 triangular or rectangular. 

14. A product according to any one of claims 4-13, 
in which the effective diameter of the marks is approxi- 
mately 50% to 240% of the displacement of the mark rela- 
tive to its nominal position. 

15 15 . A product according to any one of the preceding 

claims, in which the coding pattern is optically read- 
able. 

16. A product according to claim 15, in which the 
coding pattern is readable by infrared light. 
20 17. A product according to any one of the preceding 

claims, in which the product has a surface which is pro- 
vided with the coding pattern. 

18. A product according to any one of the preceding 
claims, in which the marks constitute 0.25% to 20%, pre- 

25 ferably approximately 9%, of the surface which is provid- 
ed with the coding pattern. 

19. A product according to any one of the preceding 
claims, in which the coding pattern is a position-coding 
pattern which codes a plurality of positions on the pro- 

3 0 duct, each position being coded by means of a plurality 
of marks . 

20. A product according to any one of the preceding 
claims, in which the product is a sheet of paper. 

21. Use of a coding pattern which comprises a plura- 
35 lity of marks, each of which represents one of at least 

two different values, and which further comprises a plu- 
rality of nominal positions, each of said plurality of 
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marks being associated with a nominal position and the 
value of each mark being determined by its location rela- 
tive to its nominal position. 
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